## SSN COLLEGE OF ENGINEERING, KALAVAKKAM DEPARTMENT OF COMPUTER SCIENCE & ENGINEERING

## Compiler Design Lab - CS6612

## PROGRAMMING ASSIGNMENT-13- Implementation of control and data flow analysis

Due Date: 30.03.18 & 31.03.18

The idea of this assignment is to analyze the flow of data across alternative flows in the program to identify the reachable definitions. Further, these reachable definitions are removed. The following is the format of the code snippet that can be given as the input.



Utilize control and data flow analysis to generate and print the GEN, KILL set. Print the IN and OUT sets for the required number of iterations.

| Block B | GEN[B]  | Bit Vector | KILL[B]    | Bit Vector |
|---------|---------|------------|------------|------------|
| B1      | {d1,d2} | 11000      | {d3,d4,d5} | 00111      |
| B2      | {d3}    | 00100      | {d1}       | 10000      |
| В3      | {d4}    | 00010      | {d2,d5}    | 01001      |
| B4      | {d5}    | 00001      | {d2,d4}    | 01010      |
| B5      | ø       | 00000      | Ø          | 00000      |

|             | INITIAL                 |                          | PASS-I                  |                          |  |
|-------------|-------------------------|--------------------------|-------------------------|--------------------------|--|
| Block       | IN[B]                   | OUT[B]                   | IN[B]                   | OUT[B]                   |  |
| B1          | 00000                   | 11000                    | 00100                   | 11000                    |  |
| B2          | 00000                   | 00100                    | 11000                   | 01100                    |  |
| B3          | 00000                   | 00010                    | 01100                   | 00110                    |  |
| B4          | 00000                   | 00001                    | 00110                   | 00101                    |  |
| B5          | 00000                   | 00000                    | 00111                   | 00111                    |  |
|             | PASS-II                 |                          |                         | PASS=III                 |  |
|             | PASS                    | S-II                     | PAS                     | S=III                    |  |
| Block       | PASS<br>IN[B]           | G-II<br>OUT[B]           | PAS<br>IN[B]            | S=III<br>OUT[B]          |  |
| Block<br>B1 |                         |                          |                         |                          |  |
|             | IN[B]                   | OUT[B]                   | IN[B]                   | OUT[B]                   |  |
| B1          | IN[B]<br>01100          | OUT[B]<br>11000          | IN[B]<br>01111          | OUT[B]                   |  |
| B1<br>B2    | IN[B]<br>01100<br>11111 | OUT[B]<br>11000<br>01111 | IN[B]<br>01111<br>11111 | OUT[B]<br>11000<br>01111 |  |

## Try this example also

